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(57) Abstract 

A systcmfor recording tdcvision progrwns for subsequent viewing by a user includes a preference determination module whic 
responsive to attribute mformauon associated with television piograms viewed by the user. TTte preference determination mcduk catcgor 
the aitnbutc mformiuion m accmdancc with categorization parameters to generate recordation preference informaUon. indicative of alcvi: 
program viewmg references of the user. TTie system also includes a rcconiaiion module which is responsive to the recordation prefen 
mformauon. for causing recordation on a storage medium of subsequcnUy iransmiucd television programs, having attribute informa 
conxspondmg to the recordation preference infomiation. 
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TELEVISION PROGRAM RECORDING WITH USER PREFERENCE 

DETERMINATION 

FIELD OF THE INVENTION 

This invention relates generaUy to the field of recording of broadcast 
type television programs by viewers for subsequent viewing. 

BACKGROUND OF THE INVENTION 

Currently, recording of television programs by individuals for viewing at 
a later time, is generally performed using commercially available Video 
Cassette Recorders (VCRs). Typically, a VCR may be either manually placed 
into a record mode or may be programmed to record a selected program at a 
latertime. To program the VCR, the user either enters a date, time and channel 
of the program desired to be recorded, or enters an identification code of the 
desired program. 

Viewers of television programming increasmgly have more choices as to 
which programs to view. For example, cable television provides a dramatic 
inaease in the number of channels available to a viewer in comparison to the 
channels available by way of a conventional television antenna. Digital satellite 
systems provide even more viewing choices. Digital broadcast of programs 
over cable television systems is expected to fiirther increase the number of 
channels available to viewers. 

One effect of the increase in the number of viewing choices is increased 
difficulty in deciding uliich programs to watch. People, particularly those with 
busy schedules, may not have the tune to select and view programs to determine 
which programs they may or may not like. Programs that may otherwise be 
desirable to a viewer may never be watched if the program is broadcast at a time 
that is inconvenient for the viewer. User's may select certain programs for 
viewing to determine if they like the program. However, widi several hundred 
program selections each week, this task can take a considerable amount of time 
and is likely to cause certain desirable programs to be overlooked. 
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It would therefore be desirable to have a system that autonu^^^ 
deteimines which programs to record based on user viewng preferences. 

IdeaUy. appropriate programs matching the mer-s viewing preferences c^^^ 
then be recorded, thus relieving the user from the task of selecting programs to 
record ftom among potentially hundreds of program selections. 

SUMMARY OF THE INVENTION 

In a principal aspect, the present invention determines viewing 
preferences of a user by monitoring programs viewed by the user and causes 
recording of programs corresponding to the/user's preferences. In accordance 
with the principles of the present iAvention, apparatus for causing recordation of 
television programs comprises a preference agent for causing retrieval of 
attribute mfonnation corresponding to each television program viewed by a user 
of die apparatus. The preference agent generates classification information 
indicative of viewing preferences of die user as a function of tiie attribute 
information. A recording manager causes recordation and storage to a storage 
device of television programs having attribute information diat matctes die 
classification informatioa 

Embodiments employing die principles of the present invention 
advantageously cause recordation of programs that match certain viewing habits 
of tire viewer. Such embodiments therefore provide tiie viewer widi stored 
programs tiiat match certain viewmg preferences of tiie user, which can be 
viewed at tiie viewer's leisure. The viewer is tiierefore relieved of tiie burden of 
deciding which programs from among several hundred possible programs to 
watch.' 

In accordance witii a further aspect of tiie present invention, programs 
may be recorded for storage m accordance witii available capacity of die storage 
device. Moreover, programs may be deleted in response to selections by tiie 
' user or based upon a priority, indicated by viewing preferences of tiie user. in 
which programs having lowest priority are deleted first to make room for newly 
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recorded program^ TTie priority of programs may also be a function of time, in 
which more recently recorded programs are ^ven higher priority. 

In accordance with further aspects of the invention, detem 
programs to record may also be a function of priority in which programs 
specified for recordation are given highest priority, foUowed by programs 
having attribute information corresponding to one or more user specified 
criteria, (hen foUowed by programs having attribute information corresponding 
to the recordation preference information. 

In accordance with fiirther aspects of the invention, the user specified 
requests may be in the form of a first type of request comprising information 
indicative of a specific program and a second ty^ of request comprising 
specifications indicative of one or more programs having attribute information 
corresponding to the usor's specifications. 

In accordance with further aspects of the invention, the user may cause 
15 recordation of a currently broadcasted program being viewed by the user by 

causing generation of a pause input This advantageously allows a user to 
interrupt viewing of a currently broadcasted program by recording the 
remainder of the program for subsequent viewing. Program viewing options 
may be presented to the user in the form of a menu that provides an easy to use 
20 interface for selection of programs and viewing and other options including 

play, pause, delete, fast-forward, rewind and so forth. 

Preferably, the preference agent organizes the recordation preference 
information in the fonn of a database organized in accordance with 
categorization parameters. Programs may be received in either analog or digital 
25 fomiats. Programs stored in digital format are advantageously presented to the 

user in the form of additional channels. This allows the user to easily switch 
between programs (either recorded or broadcast) simply by switching channels. 
These and other features and advantages of the present invention may be 
• better understood by considering the following detailed description of a 



-3" 



Okie rv^rtrv Mtn e»K7yJAi I « 



PCr/US99/12,94 

preferred embodiment of the inventica In the course of this description, 
reference will frequently be made to the attached drawings. 



BRIEF DESCRIPTION OF THE DRAWINGS 

Figure 1 is ahigh-level block diagram of a system employing the 
5 principles of the present mvention. 

Figures 2 and 3 are block diagrams illustrating operation of certain 
fimctions performed by the television recording system of Figure L 

Figures 4, 5, 6, 7, 8(a) and 8(b) are flowcharts illustrating additional 
aspects of operation of the preference agent of Figure 1 . 
10 Figures 9(a) and 9(b) illustrate altemative hardware configurations in 

systems embodying the principles of the present invention. 

Figure 10 is a flowchart illustratmg additional aspects of operation of the 
television recording system of Figure 1. 

DETAILED DESCRIPTION OF THE PREFERRED EMBODIMENTS 
1 5 In Figure 1 , a television control system 1 00 operates in accordance with 

the principles of the present invention to cause recordation of television 
programs in response to user mputs 1 02 and television signals 104. Television 
control system 100 transmits signals to a television monitor 108 for viewing by 
the user. Preferably, in digital embodiments, programs that are recorded by 
20 system 1 00 are presented to the user in the form of additional channels. Thus, 

tiie user can rapidly determine, by changing channels, tiie stored programs that 
are available for viewing. The user can also change channels between stored 
programs or between stored programs and currentiy broadcasted programs. If 
the user changes channels from a recorded program to another program, 
25 playback of the recorded program is preferably paused. Alternatively, whether 

the playback of the recorded program is paused or continued, is a user selectable 
option. As described further herein, the user may specify programs for 
recordation by specification of a particular program, or by specification of 
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particular atdbmesofthe program such as comedy/ drama, ac^ When 
manually spaifying programs for recordation, the user may specify that the 
program is to be recorded once or repeatedly, such as weekly, vAim broadcast 
Signals 104 include a first component 105 which contains the 

5 information necessary to display video and audio conyjonents of a television 

program on television monitor 108. Signals 104 preferably also include a 
second component 107 termed herein "attribute information." An example of 
such attribute information 1 07 is the information available by way of the 
DVB-SI and ATSC-SI formats and various proprietary formats such as 

10 StarSight EPG Data and TVData available from StaiSight Telecast, Inc., 

Fremont, CA, and TVData, Glen Falls, NY, respectively. 

Attribute information 107 for any particular program varies depending 
on the program type, but typically includes a plurality of categories such as start 
time for the program, duration of the program, the title of the program and other 

15 attributes (categories) of the program, together with an associated value 

corresponding to each of the categories. Preference agent 110 processes the 
attribute information 107 to generate "category-value** pairs 115. For example, 
if an attribute for a program is duration, then the category may be duration and 
the value for that category may be 1 20 minutes. If the attribute for a program is 

20 title, then the category may be title and the value may be "Star Wars." Other 

categoiy-value pairs for a movie may include a description category with a short 
description of the movie being the value, a primary actor category with the 
names of the primary stars of the movie being the values, a director category 
with the name of the director being the value, a theme category with the theme 

25 such as adventure, comedy being the value, and a ratings category with ratings 

by particular critics being the value. Category-value pairs for a sports game, 
such as a football game, may include names of the teams who are playing, the 
location of the game, and the specific tournament, such as the play-ofis, or 
• ' Superbowl, etc. 
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The catcgory-value pairs 115 (preference information) are indicative of 
viewingpreferencesof theuscr. Ue data shown in Figure 1 as being associated 
with the category-value pairs 1 15 contains weighting information for the 
associated category value, in addition to other information shown by way of 
example fiather below. Preference agent 1 10 maintains the preference 
informationll5inthefonnofapreferencedatabasell6. Television programs 
105 recorded by the system lOOarepreferably stored separately together with 
the associated attribute information 107. In an alternative embodiment, the 
category value pairs 1 15 (with or without the associated values) are stored with 
the television programs 105 and the raw attribute information 107 is not 
maintained by the system 100. 

Preference agent 1 10 generates, in response to user viewing habits, data 
for each category stored in preference database 1 16 and for each value of each 
category. The data generated by preference agent 1 10 for each category and 
value is preferably indicative of the amount of time that the particular category 
and/or value is watched by the user relative to the total amount of time that the 
particular category and/or value is available to be watched. The relative amount 
of time that a program is watched by a user is a convenient indication of the 
user's relative viewing preference. However, other indications of user viewing 
preferences may also be used. Program source switch 1 14 operates in response 
to user inputs 102 to select either presenUy broadcasted programs, by way of 
television signal 104 or stored programs from storage devices 106. 

Recording manager 1 12 operates to cause recordation and storage of 
television programs 105 and attribute information 107 in accordance with 
25 mformation generated by preference agent 1 1 0 and stored in preference database 

1 16. Recordmg manager 1 12 also responds to user requests to record particular 
programs and to user requests to record programs having specified category- 
value pairs. 

The signals transmitted to the monitor 108 preferably take a 
conventional analog form. Alternatively, the signals transmitted to the monitor 
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108 maybe digitally encoded The exact fonn of the signals transmitted to the 
monitor is not critical and may take a form as required by a particular monitor. 
The television signals 104 received by the television control system 100 may 
take one of a variety of signal formats includmg analog encoded signals that are 
encoded in accordance widi the well known NTSC or PAL standards. 
Alternatively, the signals 104 may be digitaUy encoded in a mann^ as 
transmitted by commercially available digital satellite systems (DSS) or in 
accordance with the MPEG-2 (Motion Picture Expert Group - 2) standard. In 
any given embodiment of television control system 100 the signal 104 may take 
a variety of the aforementioned fomis. For example, television control system 
100 may be coupled to receive inputs &om adigital satellite system, the inputs 
being digitally encoded The television control system 100 may also be coupled 
to receive inputs from a Conununity Antenna Television System (CATV) in 
which the signals are either encoded in analog or digital form. The television 
control system 100 may also be coupled to receive analog or digital signals from 
a conventional home antenna. 

The attribute information 1 07 may be transmitted to the television 
control system 100 contemporaneously with the television program 105 in a 
variety of ways including industry standards, such as DVB-SI (Digital Video 
Broadcasting-Service Information) as defined by the European 
Teleconununication Standards Institute (ETS), or the ATSC digital television 

. standard as defined by the Advanced Television System Committee (ATSC). 
By way of example, in the DVB-SI protocoli programming for the next six 
hours is transmitted every eight seconds for each channel. As a further 
exandple, program information for the next seven days is available from the 
interactive on-screen TV program guide available from StarSight Telecast, Inc. 
Pro^amming information further into the future, such as for the next seven 
days, may also be obtained in other ways. For example, by receiving the 

• mfonnation in a time-multiplexed manner over a particular channel. Such 
information can easily be transmitted when the user is performing an action thai 
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does not require a moving video image on the screen, such as when the user has 
a control menu di^layed on the screen. 

Alternatively, television control system 100 can download the attribute 
information 107 separately from the television program 105 by way of a 

5 .sq««tecommunicationsessioriviaamodemortheVerticalBlankingIntw^^^ 
(VBDcotttainedintelevisionsignals. Such separate communication sessions 
include data download mechanisms supported by the MPEG-2. DVB-SI and 
DSS protocols. 

The attribute information 107 can take a form under the DVB-SI 
10 protocol as shown below: 

event_id, 
startjime. 
duration, 
DESCRIPTORI, 
15 DESCRIPT0R2, 

DESCRffTORn. 

20 TTie eventjd field is a unique alpha-numeiic code assigned to a program. 

DESCRIPTORS can be "Short Event Descriptors," "Extended Event 
Descriptors" or "Content Descriptors" which include the following information: 
Short Event Descriptor: 
{ 

25 ' event_namejength 

event_name. 

eventjdcscriptionjength 
event description 

} 

30 Extended event descriptor 

{ 

ITEMl, 
nEM2 



35 



ITEMn. 
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content descriptor 

{ 

CONTENTl. 
C0NTENT2, 

CONTENTa 

} 

ITEMS include the following infonnation: 
{ 

itcm^descriptionjength, 
itcm^description, 
item^valuejength, 
item_value 

) - 
An example of item descriptions can be "Director" and item value can be 
••Martin Scorcese". CONTEhTT includes the foUowing information: 

{ 

DVB-SI defined theme, 
DVB-SI defined sub-theme, 
programmer defined theme, 
programmer defined subtheme, 

} 

An example of theme and sxibtheme are MOVIE and COMEDY, respectively. 
The programmer defined theme and sub-theme are values that may be provided 
by the EPG Data provider. 

Category-value pairs 1 15 are generated firom the above type of 
information. The category-value pairs 1 15 take the following format: Category 
Name - Category Value, where category name can be "Title "Director", 
"Theme", "Program Type" etc. and category values can be "Seinfield" "Martin 
Scorcese", "Comedy", "Sitcom" etc. Generation of categoiy-value pairs 1 15 
firom attribute information 107 allows generation by preference agent 1 10 of 
categories that are not explicitly present in the attribute information 107. For 
. example, category-value pairs 1 15 can be: Titie49ers, Description-football, and 
Description Search Rule-football(AND) San Francisco. Thus, preference agent 
1 10 is capable of generating category-value pairs 115 from attribute information 
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1 07 even where there is no field in the attribute information that coiresponds to 
the created category-value pair. 

Preference database 1 16 is preferably generated initially by downloading 
categoiy-value pairs from a third-party source such as StarSight Telecast, he. 
Advantageously, such sources may provide information customized for 
particular geographical areas and dates. For example, the database may contain 
data that gives sporting events involving local teams higher ratings than other 
sporting events. In addition, seasonal or holiday programs may be indicated as 
being preferred during particular seasons or holidays. For example, programs 
involving summertime activities would be indicated as haying higher weighting 
during the sununer than at other times qf the year. The preference database is 
modified as described herein m accordance with the user's viewing habits. In 
addition, the preference database can be periodically updated fi-ora third-party 
sources to reflect the aforementioned seasonal or holiday updates. 

Categories in the preference database 1 16 are cither predefined, such as 
those received from third-party sources, or are dynamically created from 
attribute information 107 received for programs 105. Categories, and associated 
values, that are dynamically created are preferably given a default rating by 
preference database 1 1 6. An example of the preference information created by 
preference agent 1 1 0 or downloaded to preference agent 110 is shown below. 
In the following example, the three columns of numbers in the category 
statistics and value statistics portions indicate weighting (in a range of 0 to 
1000), duration watched (in seconds) and amount of time that programs 
matchmg that particular category or value was available (in seconds). The 
information is preferably stored in the form of database records. 
Categories: 

channel 1000 



tide ' 



1001 
1002 
1003 
1004 
1005 
1007 



description 



tiUe-Substring 
genrelnfo 



descSubString 
episodeName 
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type 


1008 




stars 


1009 




director 


1010 




YearProduced 


1011 


5 


MPAARATING 


1012 




criticRating 


1013 




Values: 






Titanic 


2000 


10 


Ami 


2001 




3rd Rock From the Sun 


2002 




The Gods Must Be Cra^ 


2003 




Seinfeld 


2004 




Headline News 


2005 


15 


BuES & Dafiy 


2006 




News 


2007 




004 


2008 




005 


2009 




063 


2010 


9ft 




2011 










rOMEDY 


2ftn 




MOVIE 


2014 




NEWS 


2015 


0^ 

i^j 


^j)Tifr!)nri(!m 40ptq 


2ftl6 




A f^nlfp Hnttl<* raKP<i 

t\ W\JIWv UUlUw ioiOwd 






Isavnf* fnr fi tnnp ftT 
ilaVUv ivi a UlUw Ui 






African bushmen 


2017 






901 R 






2019 




Man US Wevers 


2020 




Sandra Prinsloo 


2021 




"JefFBridees • 


2022 




Valerie Perrine 


2023 




Phil Hartman 


2024 




• Jamie TJvs " 


2025 




Lamont Johnson 

Jj/il ill V* i t % v\/AAji^wi« 


2026 




1981 


2027 




1973 


2028 




1996 


2029 




THREESTAR 


2030 




TWOSTAR 


• 2031 




• NUDITY 


2032 




VIOLENCE 


2033 


■45 


adultsituahons 


2034 
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ADULTLANGUAGE 


2035 






Category • Value pairs: 








1001 


2001 






5 


1001 


2002 








1001 


2003 








1001 


2004 








1001 


2005 








1001 


2008 






10 


1000 


2009 








1000 


2010 








1002 


2011 








1003 


2012 








1003 


2013 






15 


1003 


2014 








Category statistics: 








1001 




1000 


31104 4022?xn 


20 


1002 




1000 


31104 4(D17R(\ 




1003 




1000 


31104 2613384 




1004 




1000 


20304 1996596 




1005 




1000 






1006 




1000 




25 


1007 




1000 






lOOS 




1000 






Value statistics: 








2001 




1000 


1638 88074 


30 


2002 




1000 


6714 178560 




2003 




1000 


6552 387054 




2004 




1000 


5400 165600 




• 2005 




1000 


1800 9000 




2006 




1000 


3600 28800 


35 . 


2011 




500 


1800 10800 



In the above example, fourteen categories are provided (1000 - 1013) 
followed by thirty-six values. The correspondence between the categories and 
valu?s (category-value pairs) is next shown. Data for the categories and then 
the values is shown next This data is organized in three columns as described 
40 ' above. 
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Piefcrence.ratmgs for programs are preferably computed by preference 
agent 110 from data stored in preference database 1 16 in accordance with the 
following formula: 



where, 

Wvj = weighting of i* value; 

Wc(Vi) = weighting of the category correspondmg to the value; 

DWvj = duration watched for the i* value; 

DAvj = duration av^ability for the value. 

The summations shown m the above equation are performed for all 
values of i, where Vf is a value in a category-value pair derived from the attribute 
information for the program. 

The above foraiula is merely an example fomiula for computing 
preference ratings. The above formula may be modified in a n\imber of ways to 
achieve different preference ratings. For example, certain category-value pairs 
may be weighted in the formula to achieve certain preference objectives. 

la the embodiment shown in Figure 1 and described above, the ratings 
for categories and values are dynamically generated by the preference agent 110 
instead of being stored the in preference database 116. In an alternative 
embodiment, the ratings may be stored in preference database together with the 
category-value pairs. 

' Television control system 1 GO is preferably implemented by way of a 
general purpose digital computer and associated hardware that executes stored 
programs to implement the functions shown withm block 1 00 in Figure 1 . The 
exact hardware and software platforms on which the television control system 




W.*Wc(^*DW. 
DA, 



Rating 
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1 00 is implemented is not important and may take a variety of forms. For 
example, television control system 100 may be implemented in a set-top box 
such as may typicaUy be used by individuals in the home to receive CATV 
signals. Another implementation of television control system 100 is in the foim 
of a personal computer configured with the requisite hardware and software to 
receive anddisplaytelevisionsignals. An example of a set-top box that maybe 
programmed in accordance with the principles described herein is described in 
the foUowing documents by BM Microelectronics: "Set-Top Box Solutions", 
Product # G522-0300.00 (Nov. 19,1 997); "Set-Top Box Reference Design Kit". 
GKIO-3098.00 (April 15.1998); "Set-Top Box Peripheral Chip", GKlO-3098- ' 
00, (April 15, 1998); "Set-Top Box- Solutions: Helping Customers Meet the 
ChaUenges of Convergence", G522-0300-00 (Nov. 19,1997); and "ITie 
challenges of convergence for Sct-Top Box manufacturers", G522-0302-00 
(Nov. 19,1997). An example of an Application Programming Interface (API) 
avaUable for set-top boxes which can serve as a platform for the embodiments 
described herein is described in "API Requirements for the Advanced Set-Top 
Box" pubUshed by OpenCabIc (Oct 21 .1997). An example of an operating 
system incorporating functionality to support the embodiments described herein 
is available from OpenTV, Inc. and is described in the following Technical 
White Paper publications by OpenTV, Inc.: "OpenTV™ Operatmg 
Environment" and "AppUcation Development for OpenTVT™." An advantage 
of such an operating system is the support provided in the form of fimction calls 
to obtain attribute information 107 from &e signals 104. Alternatively, a 
general purpose operating system such as the Windows NT operatmg system 
from Microsoft Corporation may be used m conjunction with additional 
software that provides the functions required to extract the necessary 
information from attribute information 1 07 and to perform other manipulation 
of the received signals 104 and the stored information 105. 

Storage devices 106 may include a variety of different types of storage 
devices. For example, preference database 1 16 may be stored in a non-volatile. 

-14- 
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random-access semiconductor memory. Television programs 105 and attribute 
information 107 may be stored on storage devices having greater capacity such 
as a conventional magnetic, hard disk drive. In general, storage devices 106 are 
understood to encompass a variety of storage devices. The exact form of the 
storage devices 106 is not critical so long as the storage devices have the 
capacity and speed to store the necessary information. Storage devices 106 may 
also comprise a conventional video cassette recorder (VOl) which operates 
under control of system 100 to store television programs 105 and attribute 
information 107 on conventional magnetic tape. 

For the purposes of the present description, the television control system 
1 00 is presumed to be integrated into, or coupled to, a system mcluding a tuner 
and other functions necessary to receive television signals and to extract the 
attribute information 107 from the television signal and to perform other 
functions typically associated with the receipt and viewing of television signals. 
In certain embodiinents, television control system 100 may operate in 
conjunction with a database agent that facilitates mteraction with preference 
database 1 16 by causing storage and retrieval of information to or from the 
database in an optimal manner. The preference database 1 1 6 may be 
implemented by a commercially available database product such as the Oracle 
Light database product available from Oracle Coiporation which also 
incorporates the functionality to implement the data base agent described above. 

Recording manager 112 causes recording of programs 105 by 
periodically mitiating a sequence of steps shown in Figure 2. At 201, recording 
manager 1 12 sends a request to preference agent 1 10 for ratings of all programs 
at a particular time (X). or alternatively, for ratings of all programs withm a 
particular time period (X). By way of example, the steps shown m Figure 2 
may be performed every six hours. In certain embodiments, the frequency with 
which the steps in Figure 2 are performed may be changeable by the user. 
• Preference agent 1 1 0 responds at step 202 by providing ratings, from preference 
database 1 16, for each program received from recording manager 1 12. 
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Recording manager 1 12 then causes recordation of the programs at Ume X, or 
within time period X in accordance with the ratings received from preference 
agent 110. Specifically, programs having the highest rating are given highest 
preference for recordation and programs having the lowest rating are given 
lowest preference to recordation. The recordation is subject to storage edacity 
constraints. For example, if the highest rated program is one-hour long, and 
only thirty minutes of recording space is available on storage devices 106, then 
the one-hour program is skipped and the highest rated thirty-minute program is 
recorded. 

Highest priori^ for recordmg of programs is given to programs 
specifically requested by the user. ForHCxample, if the user identifies a 
particular program for recording, such as by specifying the date, time and 
channel, or by spedfying an identification code for the program, recordation of 
that program is gvoi priority over programs rated by the preference agent 
1 5 Next highest prioriQr is given to programs matching particular category-value 

pairs specified by the user. For example, if the user does not identify a 
particular program, but specifies that one-hour long documentaries pertaining to 
travel should be recorded, then recordation of programs matching such 
category-value pairs is given priority over programs rated by the preference 
20 agent 1 10. In alternative embodiments, relative priority between user-specified 

programs, user-specified category-value pairs and programs rated by the 
preference agent 1 10 is changeable by the user. 

Recording manager 1 12 manages storage capacity on storage devices 
106 by causing deletion of television programs 105 in accordance with ratings 
25 of such programs generated by preference agent 1 1 0. This is performed in a 

manner similar to that explained above for determining which programs to 
record. Figure 3, which shows the steps taken by recording manager 1 12 to 
determme which programs to delete, is sunilar to Figure 2. At step 301, 
• recording manager 301 requests ratings from preference agent 1 10 of all 
30 programs stored on storage devices 1 06. At step 302, preference agent 1 1 0 
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responds by providing the requested deletion ratings. At step 303, recording 
manager 1 12 responds by causing deletion, when needed, of programs in 
accordance with the deletion ratings received fiom the preference agent 110. 
Specifically, when additional space on storage devices 106 is required to record 

5 one or more additional programs, recording manager 112 causes deletion, or 

overwriting of programs having the lowest rating fiisL Thus, stored television 
programs v*ich are detamined by preference agent 1 10 to be least preferable, 
m relation to otiier stored television programs, are deleted or replaced first, and 
tiiose detomined to be most preferable are deleted or replaced last Deletion of 

10 programs occurs only when required. Advantageously, this results m storage 

device 106 typically bemg filled to maximum capacity, tiius providing the user 
with as wide a variety of programs as possible. The user can speciiy programs 
that are to remain on the storage device 106. Such programs are not deleted by 
tiie recording system 100 in tiie steps shown in Figure 3. In addition, the user 

15 can specify programs tiiat are to be deleted, and tiierefore override the steps 

shown in Figure 3. 

Figure 4 illustrates actions perfomied by preference agent 110 when tiie 
user watches a television program 105. The steps shown in Figure 4 are termed 
herein a "Category Update Routine". The routine is entered at step 400 and at 

20 step 402, a duration tiueshold is checked to determine if die user has viewed tiie 

program for more than a predetermined nimimum time tiireshold. This 
advantageously avoids updating of categories for programs which may be 
viewed very briefly for example by quickly sequencing tiirough multiple 
channels to determine which programs are currentiy being broadcast At step 

25 404, the appropriate category-value pairs corresponding to tiie program are 

determined. For example, if tiie program being viewed is an action movie, then 
tiie program type category is assigned tiie value "movie", and tiie tiieme 
category is assigned tiie value "action." If tiie program being viewed is a 
• situation comedy, tiien tiie program type category is assigned tiie value 

30 "SITCOM", and die tiieme category is assigned tiie value "comedy." At 406, tiie 
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category-value pairs for the program being watched are used to update statistics 
for the categories and coiresponding values stored in the preference database. 
The prefeience database 1 16 is therefore updated to reflect the user's viewing of 
the particular program. The duraUon threshold may be eidier predetermined and 
set or may be variable depending on user preferences. For example the user 
may be able to enter the duration threshold into the television control system 
1 00 by way of a number of conventional means includmg a menu driven system 
presented on the television screen by the television control system 100 that 

prompts the user for specific information including the value of theduration 
threshold. 

Figure 5 shows in further detail-, step 406 of updating statistics for the 
categoiy-valuepans. As shown m step 500 the steps in Figure 5 are repeated 
for all categories received by way of signal 104. First, at step 502, the category 
in question is checked with the categories m the database 1 16 to determine if 
that category is cuirently stored in the database. If the category is not stored in 
the database, then at step 504. the category is added to the preference database 
1 16. The category is added to the database with a default weighting value. 
After step 504, or after step 502 if the category in question is m the database 
116, the length of time or the duration for which the program in question is 
watched by die viewer is added to a watched statistics variable for the particular 
category. Next, at step 508. the database is queried to determme if the category 
value in question is currently stored in the database. If the category value m 
question is not stored m the database, then the database 1 1 6 is updated at step 
510 with the category value in question. The category value is added to the 
database with a default rating. Next, or after step 508 if the category is in the 
database, at step 512, the duration for which the program was actually viewed is 
added to the watehed statistics for the category value. The routine is tiien 
termmated at step 514. 

Availability statistics for programs cuirentiy being broadcast are updated 
by system 100 when the user is watching a currentiy broadcast program. The 
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steps performed to implement this function are shown in Figure 6. As shown in 
steps 602 and 604, the further steps in Figure 6 are repeated periodically every 
few minutes for every currently broadcasted program. The frequency with 
which the steps in Figure 6 are performed is preferably set to a default value that 
is then subsequently changeable by the user. As shown at step 606, the further 
steps are also repeated for all categories contained in the program attributes 107. 
At step 608, each category for the program in question is compared against the 
categories stored m the database 1 16. If the category is not in database 1 16, 
then that category is skipped, as shown at step 610. If the category is b the 
database, then the category is updated by adding the value N to the availability 
statistics for the category. Next at steps 614, 616 and 61 8, for each category 
value that is in the database the availability statistics for that categoiy value are 
iq)dated by adding the value N to each availability statistic. The routine is then 
terminated at 620. In the event that the same program is broadcast on two 
channels at the same time, the availability statistics for that program are updated 
only once, thus ignoring the dual or more concurrent broadcast of the program. 

Figure 7 illustrates in further detail the process by which statistics are 
downgraded (or aged) and invalidated. Figure 7 shows two parallel paths. The 
path on the right, with reference numerals 704-714, are the steps to downgrade 
^ and invalidate categories m the database 116. On the left, steps 71 6 to 726 are 
the steps to degrade and invalidate category values m the database. The steps 
perfonned for each path 704 to 714 or 716 to 726 are identical. Accordingly, 
only steps 704 to 714 are explicitly described herein with the understanding that 
•step 716 to 726 operate in an identical fashion for category values as opposed to 
categories. As seen at step 704, the subsequent steps are repeated for all 
categories in the database 1 16. First, at step 706, the watched statistics are 
multiplied with a watched degradation co-efficient. The watched degradation 
co-efficient is preferably set to a default value that is then changeable by the 
• user. The watched degradation co-efficient reflects an amount by which a 
program that is watched by the user is degraded in priority for deletion fi:om 
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Storage. At step 708, a test is performed to determine if the watched statistics is 
less than a watched statistics degradation threshold value. If so, then at step 710 
the particular category is deleted from the database 1 16. Therefore, if a 
particular category has not been watched for a period of time by the user, then 
the watched statistics for that category will eventually fell to below the watched 
degradation threshold, at vi*ich point that category will be deleted as shown in 
step 710 from the database. In cMtain embodiments the watched degradation 
toeshold may be user programmable. At step 712, the availability statistics are 
multiplied wifli an availability degradation co-efficient that is indicative of an 
amount by vrhich statistics are aged over time. The routine is exited at step 714. 
in certain embo^ents the avmlability degradation coefBcient may differ for 
different categories. This advant^eously allows different categories to be aged 
at different rates. In certain embodimmts, the various availability degradation 
coefficients may be user changeable. As noted above, steps 716 to 726 operate 
in a similar feshion for category values. 

Figures 8(a) and 8(b) show the steps performed to update predefined 
categories and values stored in database 11 6. As shown in step 802 the steps in 
Figures 8(a) and 8(b), are repeated periodically every M days. The value M is 
preferably set to a default value, which then may subsequently be modified by 
the user. First, at step 804, a predefined category file is downloaded by the 
television control system 100. TWs may occur in a number of ways, as 
previously described, such as, for example, by use of the vertical blanking 
interval (VBI), or in a separate conmiunication session by use of a modem. As 
. shown in step 806 the subsequent steps are repeated for all categories contamed 
in the predefmed category file. At step 808 each category in the predefined 
category file is checked to deteraiine if that category is in the database 1 16. If 
the category is not in the database then it is added in step 81 0 with defeult 
weighting. If the category is in the database, or after step 808, a test is done at 
' step 8 12 to determine if the predefined file contmns a weighting for the 
particular category. If so, then at step 814 the particular weighting is updated in 
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the database. At step 816, a test is performed to detennine if there is a watched 
statistic specified in the predefined file for the particular category. If so, then at 
step 818 ivatched and availability statistics are iq)dated for the particular 
category. 

Continuing to Figure 8(b), as ^ovm in step 820, the subsequent steps 
are repeated for all values for die particular category. At step 877, the database 
1 16 is checked for each category to determine if there is a category value 
corresponding to the particular category in the database 1 16. If not, then at step 
824 the category value is added to the database 1 1 6 with de&ult weighting. If 
so, or after step 824 is completed, a test is performed at step 826 to determine if 
there is weighting specified in the predefined file for the category value. If so, 
then die weighting is updated for the category value in the database 1 16. If not, 
or after step 826, a test is performed at step 830 to detemiine if there is a 
watched statistic specified in die predefined file for the category value. If so, 
then at step 832 the watched availability statistics are updated for die category 
value. The routine is terminated at 834. 

In certain embodiments, the preference database is used by system 100 
to alter die manner in which information about cunentiy broadcasted programs 
is presented to die user. For example, in such embodiments, the preference 
database is used to rearrange the order in which currentiy broadcasted programs 
are presented to cause programs having attribute information 1 07 mted highest 
by preference database 1 16 to be presented first Alternatively, tiie preference 
database 1 16 can be used to organize information regarding the currentiy 
broadcasted programs according to the various category-value pairs stored in the 
database 116. 

Figures 9(a) and 9(b) illustrate alternative hardware configurations for 
. systems employing die principles of die present invention. Figure 9(a) 

illustrates a hardware configuration diat supports storage and retrieval of 
. digitally encoded audio and video, bterface 902 is a standard digital cable or 
digital satellite input interface. Interface 906, which is the hardware interface to 
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Storage devices 1 06 preferably takes the form of an DDE or SCSI interface, or 
the proposed IEEE-1394 inter&ce. Interface 906 is an NTSC or PAL encoded 
video interfecc. If the television signal 104 takes the form of an analog signal, 
as in the case of most current television broadcast signals, and CATV signals, 

5 then the signal 104 must be digitized and generally compressed (for exam . 

tiie MPEG-n standard) before storage on a digital storage medium such as 
shoAvn in Figure 9(a). 

Figure 9(b) illustrates an embodiment using an analog storage device 
106 such as a conventional VCR. If the television signal 104 is analog then the 

10 interface 910 takes the form of a conventional NTSC or PAL interface. If the 

television signal 104 is digital then the interface 910 takes a form as interface 
902 shown in Figure 9(a) and a digital-to-analog converter is required to convert 
the received signal to analog form before storage on storage device 106. 

Figure 10 illustrates operation of an automatic pause-record feature of 

1 5 preferred embodiments. If a user is watching a currently broadcasted program 

and wishes to stop or temporarily pause viewing of the program, the recording 
system 100 advantageously allows the program to be recorded so the user can 
resume viewing the program at a subsequent time. As shown in Figure 10, at 
1002, the user is viewing a currently broadcasted program. Generation of a 

20 pause input at 1 004 by the user, such as by pressing of an appropriate button on 

a remote control coupled to the recording system 100, causes the system 100 to 
cause at 1006, recordation of the program being viewed by the user. The user is 
then free to watch another program or stop watching the television 108 
altogether. At a subsequent point in time, if a resume viewing input is received, 

25 such as by pressing of an appropriate button on the aforementioned remote 

control, then at 1010, the recording system 100 causes the program recorded at 
step 1006 to be retrieved and shown on the television 108 from the point the 
recordation was initiated at step 1006. If the program is still being broadcast 
' when step 1010 is initiated, then recordation of the program continues by the 
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system 100. TTie user thus can easHy mtemipt viewing of a currenUy broadcast 
program and resume subsequent viewing. 

Preferably, the recording system 100 supports a variety of functions such 

as fest-forvmni, rewind and visual scan of stored programs, and other functions 
5 supported by the storage medium 106. For example, if the storage medium 106 

takes the form of a VCR then the program viewmg and manipulation functions 
wiU be limited to the standard VCR functions of fest-forward, rewind, forvrard 
or reverse visual scan. If the storage device 106 takes the form of a digital 
storage medium then more advanced program search and retrieval functions can 
10 be supported. 

It is to be tmderstood that the speci'fic mechanisms and techniques which 
have been described are merely illustrative of one application of the principles 
of the invention. For example, the functions perfonned by the preference agent 
1 10 and the recording manager 1 12 are illustrative of a particular embodiment. 
15 However, the division of tasks between the two modules 1 10 and 112 may be 

changed. In addition, the data formats 1 1 5,1 1 6,105 and 107 may also take a 
variety of forms. Numerous additional modifications may be made to the 
metiiods and apparatus described witiiout departing from die true spirit of the 
invention. 
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WHAT IS CLAIMED IS: . 

L Apparatus for causing recordation of television programs 
comprising: 

a preference agent for causing retrieval of attribute information 
corresponding to each television program viewed by a user of said apparatus, 
said preference agent generating classification information indicative of viewing 
preferences of said user as a function of said attribute information; and 

a record manager for causing recordation and storage to a storage 
medium of television programs having attribute infomiation that matches said 
classification infomiation. 

2. Apparatus as set forth in claim 1 further comprising a storage 
medium manager comprising: 

means for causing deletion of television programs stored on said storage 
medium as a function of age of said television programs; 

means for causing deletion of television programs stored on said storage 
medium as a function of viewing fi-equency of said program by said user; and 

means for causing deletion of television programs stored on said storage 
medium as a function of program deletion inputs firom said user identifying one 
or more programs to be deleted from said storage medium. 

3. In a system that receives television signals carrying television 
programs, a computer storage medium comprising apparatus for causing storage 
of selected ones of said television programs for subsequent viewing by a user of 
said apparatus, comprising: 

a preference determination module, responsive to attribute information 
associated with television programs viewed by said user, for categorizing said 
attribute information in accordance with categorization parameters to generate 

.24- 



wo 99/65237 «r-T.«,.<.. 

PCTAJS99/12194 

recordation preference infonnation, indicative of television program viewing 
preferences of said user, and 

a recordation module, responsive to said recordation preference 
information, for causing recordation on a storage medium of subsequently 
5 transmitted television programs, having attribute information corresponding to 

said recordation preference informatioa 

4. Appaiams as set forth in claim 3 wherein said recordation 
module is foither responsive to an available capacity value, indicative of 
available storage capacity of said storage medium on which said subsequently 
10 transmitted television programs are stored, for causing storage of said television 

programs having attribute information correspondmg to said recordation 
preference information in accordance with said available capacity value. 



5. Apparatus as set forth in claim 3 vvherein said recordation 
preference information comprises program deletion information indicative of 
15 priority in which television programs stored on said recordation module are 

deleted jfrom said storage medium, as uidicated by viewing preferences of said 
user, and wherein said recordation module responds to said program deletion 
information by causing replacement of television programs having lowest 
* priority with newly stored television programs. 



20 6. Apparatus as set forth in claim 5 wherein said program deletion 

information is periodically updated as a function of time. 

* 7. Apparatus as set fortii in claim 5 further comprismg means, 
responsive to one or more user inputs, for preventing updating of selected ones 
of said programs as a function of time. 
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8. Apparatus as set forth in claim 5 whereb said program deletion 
information is periodically updated as a function of programs viewed by said 
user. 



9. Apparatus as set forth in claim 3 whereb said recordation 
preference information comprises recordation priority mfoimation indicative of 

apriority in which programs are recorded for storage on said storage medium, 
and wherein said recordation preference information is generated by assigning 
highest priority to programs requested for storage by said user, assigning lowest 
priority to programs having attribute infomaation corresponding to said 
recordation preference information and assigning intermediate priority to 
programs having attribute information corresponding to one or more user 
specified criteria. 

10. Apparatus as set forth m claim 3 wherein said recordation 
module is further responsive to user specified requests to cause recordation on 
said storage medium of subsequently transmitted television programs. 

1 1 . Apparatus as set forth in claim 10 wherein said user specified 
requests comprise a first type of request comprising information indicative of a 
specific program and a second type of request comprising attribute information 
indicative of one or more programs having attribute mformation corresponding 
to said user specified attribute mformation. 

12. Apparatus as set forth in claim 3 wherein said preference 
determination module organizes said recordation preference information in the 
form of a database organized according to said categorization parameters. 

13. Apparatus as set forth in claim 3 wherein said recordation 
module comprises means, responsive to a first user request, for causing a 
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selected program to be recorded once for storage on said storage medhun, and 
responsive to a second user request, for causmg a selected program to be 
recorded periodically for storage on said storage medium. 

14. Apparatus as set forth m claim 3 wherein said recordation 
module compri^ means, responsive to a category recordation request by said 
user, for causing recordation of programs having attribute infoimadon 
corresponding to user specified attribute information. 

15. Apparatus as set forth in claim 3 further comprising means, 
responsive to a pause input firom said user, for causing recordation of a currently 
broadcasted program being viewed by said user. 

16. Apparatus as set forth m claim 3 further comprising means, 
responsive to a pause input from said user, for causing pausing of a recorded 
program being viewed by said user. 

17. Apparatus as set forth in claim 3 fiirther comprising means, 
responsive to a channel selection input from said user, for causing changing of a 
first channel corresponding to a currently broadcasted program to a second 
channel corresponding to a recorded program. 

1 8. Apparatus as set forth in claim 3 further comprising means, 
responsive to a channel selection input from said user, for causing changing of a 
first channel corresponding to a recorded program to a second channel 
corresponding to a cunently broadcasted program. 

19. Apparatus as set forth in claim 3, wherein said storage means 
stores randomly accessible, digitally encoded data and wherein said apparatus 
finther comprises means, responsive to a channel selection input from said user. 
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for causing chan©ng of a fiist channel conesponding to a first recorded 
program to a second channel conesponding to a second recorded program. 



20. Apparatus as set forth in claim 19 wherein said means responsive 
to a channel selection input from said user is further responsive to a first pause 
input, for causing pausing of said first recorded program chamiel upon changing 
of said first channel to said second chaimel. 



21. Apparatus as set forth mdaun 20 wherein said means responsive 
to a channel selection input firom said user.causes said first recorded program to 
continue playing upon changing of said first channel to said second channel in 
the absence of smd first pause input 



22. Apparatus as set forth in claim 3 fiirther comprismg means, 
responsive to a user delete input, for causing deletion of a selected program 
from said storage medium. 

23. Apparatus as set forth in claim 3 fiirther comprising: 
means, responsive to a user program selection input, for causing 

generation of a user selection menu on said television, said user selection menu 
providmg said user with a pluraUty of options comprismg, an option to play a 
selected program, hold a selected program, delete a selected program, play a 
selected program fi^m the beginning of said program, fest-forwaid a selected 
P"ogiam or rewind a selected program; and 

means, responsive to user selection of one of said options, for causing 
execution of said selection option. 

24. Apparatus as set forth in claim 23 wherein said means for 
causing generation of a user selection menu on said television is responsive to a 
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menu view input received during vievdng of a program for causing generation 
of said user selection menu on said television. 
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